@import "tailwindcss";
@import "fumadocs-ui/css/black.css";
@import "fumadocs-ui/css/preset.css";

@plugin "tailwindcss-animate";

@custom-variant dark (&:is(.dark *));

:root {
	--background: oklch(1 0 0);
	--foreground: oklch(0.147 0.004 49.25);
	--card: oklch(1 0 0);
	--card-foreground: oklch(0.147 0.004 49.25);
	--popover: oklch(1 0 0);
	--popover-foreground: oklch(0.147 0.004 49.25);
	--primary: oklch(0.216 0.006 56.043);
	--primary-foreground: oklch(0.985 0.001 106.423);
	--secondary: oklch(0.97 0.001 106.424);
	--secondary-foreground: oklch(0.216 0.006 56.043);
	--muted: oklch(0.97 0.001 106.424);
	--muted-foreground: oklch(0.553 0.013 58.071);
	--accent: oklch(0.97 0.001 106.424);
	--accent-foreground: oklch(0.216 0.006 56.043);
	--destructive: oklch(0.577 0.245 27.325);
	--destructive-foreground: oklch(0.577 0.245 27.325);
	--border: oklch(0.923 0.003 48.717);
	--input: oklch(0.923 0.003 48.717);
	--ring: oklch(0.709 0.01 56.259);
	--chart-1: oklch(0.646 0.222 41.116);
	--chart-2: oklch(0.6 0.118 184.704);
	--chart-3: oklch(0.398 0.07 227.392);
	--chart-4: oklch(0.828 0.189 84.429);
	--chart-5: oklch(0.769 0.188 70.08);
	--sidebar: oklch(0.985 0.001 106.423);
	--sidebar-foreground: oklch(0.147 0.004 49.25);
	--sidebar-primary: oklch(0.216 0.006 56.043);
	--sidebar-primary-foreground: oklch(0.985 0.001 106.423);
	--sidebar-accent: oklch(0.97 0.001 106.424);
	--sidebar-accent-foreground: oklch(0.216 0.006 56.043);
	--sidebar-border: oklch(0.923 0.003 48.717);
	--sidebar-ring: oklch(0.709 0.01 56.259);
	--scrollbar-thumb: var(--border);
	--scrollbar-thumb-hover: var(--ring);
	--scrollbar-track: transparent;
	--radius: 0.2rem;
	--fd-nav-height: 56px;
	--fd-banner-height: 0px;
	--fd-tocnav-height: 0px;
}

.dark {
	--background: hsl(0 0% 0%);
	--foreground: oklch(0.985 0.001 106.423);
	--card: oklch(0.147 0.004 49.25);
	--card-foreground: oklch(0.985 0.001 106.423);
	--popover: oklch(0.147 0.004 49.25);
	--popover-foreground: oklch(0.985 0.001 106.423);
	--primary: oklch(0.985 0.001 106.423);
	--primary-foreground: oklch(0.216 0.006 56.043);
	--secondary: oklch(0.268 0.007 34.298);
	--secondary-foreground: oklch(0.985 0.001 106.423);
	--muted: oklch(0.268 0.007 34.298);
	--muted-foreground: oklch(0.709 0.01 56.259);
	--accent: oklch(0.268 0.007 34.298);
	--accent-foreground: oklch(0.985 0.001 106.423);
	--destructive: oklch(0.396 0.141 25.723);
	--destructive-foreground: oklch(0.637 0.237 25.331);
	--border: oklch(0.268 0.007 34.298);
	--input: oklch(0.268 0.007 34.298);
	--ring: oklch(0.553 0.013 58.071);
	--chart-1: oklch(0.488 0.243 264.376);
	--chart-2: oklch(0.696 0.17 162.48);
	--chart-3: oklch(0.769 0.188 70.08);
	--chart-4: oklch(0.627 0.265 303.9);
	--chart-5: oklch(0.645 0.246 16.439);
	--sidebar: oklch(0.216 0.006 56.043);
	--sidebar-foreground: oklch(0.985 0.001 106.423);
	--sidebar-primary: oklch(0.488 0.243 264.376);
	--sidebar-primary-foreground: oklch(0.985 0.001 106.423);
	--sidebar-accent: oklch(0.268 0.007 34.298);
	--sidebar-accent-foreground: oklch(0.985 0.001 106.423);
	--sidebar-border: oklch(0.268 0.007 34.298);
	--sidebar-ring: oklch(0.553 0.013 58.071);
	--scrollbar-thumb: var(--border);
	--scrollbar-thumb-hover: var(--ring);
	--scrollbar-track: transparent;
}

@theme inline {
	--color-background: var(--background);
	--color-foreground: var(--foreground);
	--color-card: var(--card);
	--color-card-foreground: var(--card-foreground);
	--color-popover: var(--popover);
	--color-popover-foreground: var(--popover-foreground);
	--color-primary: var(--primary);
	--color-primary-foreground: var(--primary-foreground);
	--color-secondary: var(--secondary);
	--color-secondary-foreground: var(--secondary-foreground);
	--color-muted: var(--muted);
	--color-muted-foreground: var(--muted-foreground);
	--color-accent: var(--accent);
	--color-accent-foreground: var(--accent-foreground);
	--color-destructive: var(--destructive);
	--color-destructive-foreground: var(--destructive-foreground);
	--color-border: var(--border);
	--color-input: var(--input);
	--color-ring: var(--ring);
	--color-chart-1: var(--chart-1);
	--color-chart-2: var(--chart-2);
	--color-chart-3: var(--chart-3);
	--color-chart-4: var(--chart-4);
	--color-chart-5: var(--chart-5);
	--color-sidebar: var(--sidebar);
	--color-sidebar-foreground: var(--sidebar-foreground);
	--color-sidebar-primary: var(--sidebar-primary);
	--color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
	--color-sidebar-accent: var(--sidebar-accent);
	--color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
	--color-sidebar-border: var(--sidebar-border);
	--color-sidebar-ring: var(--sidebar-ring);
	--radius-sm: calc(var(--radius) - 4px);
	--radius-md: calc(var(--radius) - 2px);
	--radius-lg: var(--radius);
	--radius-xl: calc(var(--radius) + 4px);

	--font-sans: var(--font-geist-sans);
	--font-mono: var(--font-geist-mono);

	--animate-accordion-down: accordion-down 0.2s ease-out;
	--animate-accordion-up: accordion-up 0.2s ease-out;
	--animate-ripple: ripple var(--duration, 2s) ease calc(var(--i, 0) * 0.2s)
		infinite;
	--animate-scroll: scroll var(--animation-duration, 40s)
		var(--animation-direction, forwards) linear infinite;
	--animate-hrtl-scroll: hrtl-scroll var(--anime-duration, 10s) linear infinite;
	--animate-hrtl-scroll-reverse: hrtl-scroll-reverse var(--anime-duration, 10s)
		linear infinite;
	--animate-spotlight: spotlight 2s ease 0.3s 1 forwards;

	@keyframes accordion-down {
		from {
			height: 0;
		}
		to {
			height: var(--radix-accordion-content-height);
		}
	}

	@keyframes accordion-up {
		from {
			height: var(--radix-accordion-content-height);
		}
		to {
			height: 0;
		}
	}

	@keyframes hrtl-scroll {
		from {
			transform: translateX(0);
		}
		to {
			transform: translateX(calc(-95%));
		}
	}

	@keyframes hrtl-scroll-reverse {
		from {
			transform: translateX(calc(-95%));
		}
		to {
			transform: translateX(0);
		}
	}

	@keyframes ripple {
		0%,
		100% {
			transform: translate(-50%, -50%) scale(1);
		}
		50% {
			transform: translate(-50%, -50%) scale(0.9);
		}
	}

	@keyframes scroll {
		to {
			transform: translate(calc(-50% - 0.5rem));
		}
	}

	@keyframes spotlight {
		0% {
			opacity: 0;
			transform: translate(-72%, -62%) scale(0.5);
		}
		100% {
			opacity: 1;
			transform: translate(-50%, -40%) scale(1);
		}
	}
}

@layer base {
	* {
		@apply border-border outline-ring/50;
	}
	body {
		@apply overscroll-none bg-background text-foreground selection:bg-foreground selection:text-background;
	}
}

html {
	scroll-behavior: auto;
	scroll-padding-top: calc(
		var(--fd-nav-height, 56px) +
		var(--fd-banner-height, 0px) +
		var(--fd-tocnav-height, 0px) +
		24px
	);
}

html:not([data-anchor-scrolling]) {
	scroll-behavior: smooth;
}

/* Global, accessible custom scrollbars */
* {
	scrollbar-width: thin; /* Firefox */
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

/* WebKit-based browsers */
::-webkit-scrollbar {
	width: 12px;
	height: 12px;
}
::-webkit-scrollbar-track {
	background: var(--scrollbar-track);
}
::-webkit-scrollbar-thumb {
	background-color: var(--scrollbar-thumb);
	border-radius: 9999px;
	border: 3px solid transparent; /* creates a gap between thumb and track */
	background-clip: content-box;
}
::-webkit-scrollbar-thumb:hover {
	background-color: var(--scrollbar-thumb-hover);
}
::-webkit-scrollbar-corner {
	background: transparent;
}

@utility no-scrollbar {
	-ms-overflow-style: none;
	scrollbar-width: none;
	&::-webkit-scrollbar {
		display: none;
	}
}

@utility bg-grid {
	background-image:
		linear-gradient(currentColor 1px, transparent 1px),
		linear-gradient(90deg, currentColor 1px, transparent 1px);
	background-size: 32px 32px;
}

@utility bg-grid-small {
	background-image:
		linear-gradient(currentColor 1px, transparent 1px),
		linear-gradient(90deg, currentColor 1px, transparent 1px);
	background-size: 8px 8px;
}

@utility bg-dot {
	background-image: radial-gradient(
		circle at 50% 50%,
		currentColor 1.6px,
		transparent 1.6px
	);
	background-size: 16px 16px;
}

.markdown-content {
	@apply text-sm leading-relaxed;
}

.markdown-content pre {
	@apply max-w-full overflow-x-auto;
}

.markdown-content pre code {
	@apply whitespace-pre-wrap break-words;
}

.markdown-content h1,
.markdown-content h2,
.markdown-content h3,
.markdown-content h4,
.markdown-content h5,
.markdown-content h6 {
	@apply font-semibold text-foreground;
}

.markdown-content p {
	@apply mb-2 last:mb-0;
}

.markdown-content ul,
.markdown-content ol {
	@apply space-y-2 list-disc;
}

.markdown-content li {
	@apply text-sm;
}

.markdown-content code {
	@apply bg-muted px-1.5 py-0.5 rounded text-xs font-mono;
}

.markdown-content pre {
	@apply overflow-x-auto;
}

.markdown-content blockquote {
	@apply border-l-4 border-muted-foreground/20 pl-4 my-2 italic;
}

.markdown-content table {
	@apply w-full border-collapse;
}

.markdown-content th,
.markdown-content td {
	@apply border border-border px-2 py-1 text-xs;
}

.markdown-content th {
	@apply bg-muted font-medium;
}

@keyframes stream-pulse {
	0%,
	100% {
		opacity: 1;
	}
	50% {
		opacity: 0.5;
	}
}

.streaming-cursor {
	animation: stream-pulse 1s ease-in-out infinite;
}
